<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8" />
    <meta http-equiv="X-UA-Compatible" content="IE=edge" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <title>Document</title>
  </head>
  <body>
    <script>
      // http / 定时器 / 事件订阅
      //，前一个的结果是后一个的条件

      /*
        张三 - 1000
        李四  - 1000
        王五  - 1000
        赵六- 1000
      */

      // function findName(func, result) {
      //   setTimeout(() => {
      //     func && func(result)
      //   }, 1000)
      // }
      function findName(result) {
        return new Promise((resolve, reject) => {
          setTimeout(() => {
            resolve(result)
          }, 1000)
        })
      }

      findName('张三')
        .then((res) => {
          console.log(res, 'res')
          return findName('李四')
        })
        .then((res) => {
          console.log(res, 'res')
          return findName('王五')
        })
        .then((res) => {
          console.log(res, 'res')
          return findName('赵六')
        })
        .then((res) => {
          console.log(res, 'res')
          // return findName('李四')
        })

      // callback hell
      // findName((res) => {
      //   console.log(res, 'res')
      //   findName((res2) => {
      //     console.log(res2, 'res2')
      //     findName((res3) => {
      //       console.log(res3, 'res3')
      //       findName((res4) => {
      //         console.log(res4, 'res3')
      //       }, '赵六')
      //     }, '王五')
      //   }, '李四')
      // }, '张三')

      // function auto() {
      //   setTimeout(() => {
      //     func && func('helo world')
      //   }, 1000)
      //   // return undefined
      // }

      // let it = auto((res) => {})
    </script>
  </body>
</html>
